

**REMARKS**

Claims 5, 10, 15, and 16 are amended.

Claims 1-16 are pending.

**Regarding Proposed Changes to the Drawings**

In proposed Fig. 1, reference number "220" was changed to -- 200 -- to properly match the description beginning on page 4, line 22.

In proposed Fig. 3, the overall method's reference number was changed from "402" to -- 400 -- to properly match the description on page 9, line 12.

Consequently, it is respectfully requested that the objections to the drawings under 35 U.S.C. §1.83(a) be reconsidered and withdrawn.

**Regarding Claim Amendments**

Claims 5, 10, 15, and 16 are amended herein to provide proper grammatical/antecedent language to selected elements. These amendments were not made based on the cited art and/or for any substantive purpose relating to patentability.

**Rejections under 35. U.S.C. §102(b)**

Claims 1-16 stand rejected under 35 U.S.C. §103(b) as being anticipated by an article titled "Hardware Design of a 2-D Motion Estimation System Based on the Hough Transform", by *Hsiang-Ling Li et al.* and published in IEEE Transactions on Circuits and Systems – II: Analog and Digital Signal Processing, Vol. 45, No. 1, pages 80-95 in January 1998 (IEEE Article No. 1057-7130/98).

The Applicant respectfully traverses each of these rejections for at least the following reasons.

As originally stated in the pending application:

The Hough Transform is a well-known computer vision algorithm that can be implemented to robustly detect a wide variety of features such as lines, circles, and anything else that can be readily parameterized or otherwise cast in terms of a discrete popularity algorithm. Unfortunately, the Hough transform tends to be computationally intensive. Many personal computer (PC) microprocessors are unable to provide the requisite processing capability usually associated with the Hough Transform. (page 1, line 21)

One of the problems with past implementations of the Hough transform is that the arrays of accumulators needed for Hough transforms have historically needed to be low-resolution because of the data storage expense and execution time requirements for higher resolution arrays. This is because, high-resolution arrays require both more time to manage, and more time to analyze after the algorithm has finished processing the accumulators. As described below, the various methods and arrangements describe ways to leverage dedicated hardware to solve these problems. As will be shown, it is feasible to use an inexpensive processor that can operate on ordered data to implement the Hough transform. (page 4, line 2)

Hence, the specification clearly states that various systems exist which implement the Hough transform. However, the logic required to perform the Hough transform can be complex and/or expensive. That is why the industry is busy working on improved systems that use different solutions, optimizations, approximations, etc.

With this in mind, *Hsiang-Ling Li et al.* disclose a motion estimation system that implements a straight-line Hough transform through custom designed logic based on a feature-domain algorithm. *Hsiang-Ling Li et al.* disclose that their goal is to develop a less computationally intensive algorithm (page, 80, second column, first paragraph).

1       *Hsiang-Ling Li et al.* disclose an improved algorithm that is implemented in  
2 custom logic that includes a preprocessor block (see, Fig. 4) and a Hough  
3 Transform (HT) processor block (see, e.g., Fig. 5). The preprocessor block  
4 performs boundary-smoothing, contour tracing, contour integrating and dominant  
5 point detection. The HT processor block then processes contour segments based  
6 on the dominant points and using a vote accumulator estimates a translation vector.  
7 See, e.g., sections III-V, beginning on page 82.

8       *Hsiang-Ling Li et al.* implemented their preprocessor and HT processor  
9 blocks using conventional gate logic simulation tools available from Mentor  
10 Graphics® (see, e.g., Abstract, page 80). Thus, *Hsiang-Ling Li et al.* essentially  
11 disclose an improved algorithm that is taught and implemented using specially  
12 designed logic blocks. These specially designed logic blocks may be implemented  
13 through custom VLSI logic, standard cell logic, and/or FPGA logic (page 80,  
14 second column).

15       To the contrary, Claims 1-16 are directed towards implementing a Hough  
16 transform using a host processor and a graphics processor. Hence, there is no need  
17 to design and/or build a special purpose logic circuit as taught by *Hsiang-Ling Li*  
18 *et al.* One need only configure (e.g., program) a host processor and graphics  
19 preprocessor accordingly.

20       *Hsiang-Ling Li et al.* clearly fail to disclose or otherwise even suggest that a  
21 Hough transform may be efficiently performed by splitting up the processing  
22 between a host processor and a graphics processor as recited in the pending claims.  
23 Moreover, the algorithm taught by *Hsiang-Ling Li et al.* is different that being  
24 claimed.

25

1        The Office Action suggests that the "Mentor Graphics tools inherently  
2 provide a graphics processor". This statement is inherently wrong. As well known  
3 in the art, Mentor Graphic's tools are part of an electronic design automation  
4 (EDA) software product that allows engineers to develop logic circuits, layout the  
5 logic circuits, simulate the operation of the logic circuits, and output resulting logic  
6 design information suitable for manufacturing corresponding hardware/firmware.  
7 Thus, Mentor Graphic's tools are actually software applications for use in a  
8 computer. The computer instructions that form this software application are  
9 therefore processed as would any other application's instructions via the CPU of  
10 the computer.

11        Attention is now drawn to the pending claims.

12        **Independent Claim 1** is directed towards a method that includes providing  
13 image data and performing a Hough transform on the image data using a host  
14 processor and an operatively configured graphics processor. For at least the  
15 reasons stated above, this method is not disclosed or suggested by *Hsiang-Ling Li*  
16 *et al.*

17        **Claim 2**, which depends from **Claim 1**, further specifies that the graphics  
18 processor is configured to count votes in a resulting Hough transform voting  
19 buffer. *Hsiang-Ling Li et al.* also fail to disclose or suggest the use of a graphics  
20 processor to count votes.

21        **Claim 3**, which depends from **Claim 1**, further specifies that the graphics  
22 processor is configured to convolve image values and provide corresponding  
23 results to the host processor. Again, *Hsiang-Ling Li et al.* fail to disclose or  
24 suggest the use of a graphics processor in this manner.

25

1       **Claim 4**, which also depends from **Claim 1**, further specifies that the  
2       graphics processor performs an alpha-blending operation that selectively  
3       increments accumulators that correspond to parameter combinations that are likely  
4       associated with an observation. *Hsiang-Ling Li et al.* do not disclose or suggest  
5       the use the alpha-blending operation of a graphics processor to perform such a  
6       method.

7       In **Claim 5**, which depends from **Claim 1**, it is further recited that the  
8       graphics processor performs a histogram computation to find the maxima value in  
9       a Hough transform voting buffer. The logic taught by *Hsiang-Ling Li et al.*, which  
10      does not even include a graphics processor, does not perform a histogram  
11      computation to find a maxima value in a Hough transform voting buffer.

12      Independent **Claim 6** is directed towards an apparatus that includes a host  
13      processor and a graphics processor. As recited the host processor is configured to  
14      provide image data and the graphics processor is configured to perform selected  
15      steps of a Hough transform algorithm on the image data in association with the  
16      host processor. For at least the reasons stated above, this apparatus is not disclosed  
17      or suggested by *Hsiang-Ling Li et al.* Instead, *Hsiang-Ling Li et al.* teach that  
18      special purpose hardware or firmware (e.g., VLSI, FPGA) logic can be used to  
19      perform a straight-line Hough transform.

20      **Claim 7**, which depends from **Claim 6**, the apparatus further includes local  
21      memory that is operatively coupled to the graphics processor. Here, the graphics  
22      processor is configured to count votes in a resulting Hough transform voting buffer  
23      within the local memory. *Hsiang-Ling Li et al.* fail to disclose or suggest this  
24      apparatus.

25

1       **Claim 8**, which depends from Claim 6, further specifies that the graphics  
2 processor is configured to convolve image values and provide corresponding  
3 results to the host processor. Again, *Hsiang-Ling Li et al.* fail to disclose or  
4 suggest the use of a graphics processor in this manner.

5       **Claim 9**, which also depends from Claim 6, further specifies that the  
6 apparatus includes local memory and that the graphics processor performs an  
7 alpha-blending operation that selectively increments accumulators within the local  
8 memory that correspond to parameter combinations that are likely associated with  
9 an observation. *Hsiang-Ling Li et al.* do not disclose or suggest using the alpha-  
10 blending operation of a graphics processor in this way.

11      **Claim 10**, which depends from Claim 6, further recites that the apparatus  
12 includes a local memory and that the graphics processor performs a histogram  
13 computation to find the maxima value in the Hough transform voting buffer within  
14 the local memory. The logic taught by *Hsiang-Ling Li et al.*, which does not even  
15 include a graphics processor, does not perform a histogram computation to find a  
16 maxima value in a Hough transform voting buffer.

17      Independent **Claim 11** is directed towards a computer-readable medium  
18 having computer-executable instructions for performing steps that include  
19 providing image data and performing a Hough transform on the image data using a  
20 host processor and an operatively configured graphics processor. For at least the  
21 reasons stated above, this computer-readable medium is not disclosed or suggested  
22 by *Hsiang-Ling Li et al.*

23      **Claim 12**, which depends from Claim 11, recites that the computer-  
24 executable instructions cause the graphics processor to count votes in a resulting  
25

1 Hough transform voting buffer. *Hsiang-Ling Li et al.* fail to disclose or suggest  
2 this.

3 **Claim 13**, which depends from Claim 11, recites that the computer-  
4 executable instructions cause the graphics processor is to convolve image values  
5 and provide corresponding results to the host processor. Again, *Hsiang-Ling Li et*  
6 *al.* fail to disclose or suggest the use of a graphics processor in this manner.

7 **Claim 14**, which also depends from Claim 11, further states that the  
8 computer-executable instructions cause the graphics processor to perform an  
9 alpha-blending operation that selectively increments accumulators that correspond  
10 to parameter combinations that are likely associated with an observation. *Hsiang-*  
11 *Ling Li et al.* do not disclose or suggest using the alpha-blending operation of a  
12 graphics processor in this way.

13 In **Claim 15**, which depends from Claim 11, the computer-executable  
14 instructions further cause the graphics processor to perform a histogram  
15 computation to find a maxima value in a Hough transform voting buffer. *Hsiang-*  
16 *Ling Li et al.* do not even use a graphics processor and do not perform a histogram  
17 computation to find a maxima value in a Hough transform voting buffer.

18 A method is recited in independent **Claim 16**. The method includes causing  
19 dedicated graphics hardware to support at least one step associated with a Hough  
20 transform algorithm. Thus, the dedicated graphics hardware may quantize a  
21 bounded portion of a parameter space that may contain a desired feature. *Hsiang-*  
22 *Ling Li et al.* do not disclose or suggest this. The dedicated graphics hardware  
23 may, for each discrete quantized parameter combination, allocate an incrementable  
24 accumulator. *Hsiang-Ling Li et al.* do not disclose or suggest having a graphics  
25 processor do this. The dedicated graphics hardware may gather observations that

1 can be mapped into the parameter space. This is not taught by *Hsiang-Ling Li et*  
2 *al.* The dedicated graphics hardware may, for each observation, increment each  
3 of the accumulators that corresponds to parameter combinations that may have  
4 produced the observation. *Hsiang-Ling Li et al.* do not disclose or suggest this.  
5 The dedicated graphics hardware may determine a maxima in a resulting quantized  
6 parameter array and the corresponding parameter combinations. This also is not  
7 taught by *Hsiang-Ling Li et al.*

8 For at least the reasons stated above, it is, therefore, respectfully requested  
9 that the rejections be reconsidered and withdrawn.

10

11 **Conclusion**

12 The pending claims have been placed in condition for allowance and are  
13 clearly patentable over the cited art and should therefore be allowed.

14

15

Respectfully Submitted,

16

Date: 1/21/2004

17

By: T. A. Jolly

18

Thomas A. Jolly  
Reg. No. 39,241

19

20

21

22

23

24

25